产品动态

您的位置: 首页产品动态

最新技术更多

区块链技术| HyperLedger Fabric架构构建ERC20令牌(part I)

作者:区块链研究实验室 (文章来源——巴比特 海盗号)发布时间:2019-06-20

 

由于其高TPS和作为区块链作为服务平台的行为,许多新创新者正在选择Hyperledger来部署他们的区块链业务。因此,在本博客中,我们将讨论使用node.js在Hyperledger中创建基于erc20的令牌链代码的方法。

为何选择ERC20?

 

ERC20是以太坊广泛测试和接受的,将其整合到Hyperledger中,可以轻松地为基于Hyperledger的任何令牌编写安全且可扩展的链码。

 

我们将在本教程中参考以下开源存储库。

 

注意:我们假设您已经熟悉Hyperledger结构,并且您的系统配备了启动Hyperledger开发的先决条件。如果没有,请参阅Hyperledger文档中的先决条件、关键概念和教程。

 

此存储库中的代码已在以下环境中进行了测试:

 

1. node:v8.9.3和v8.11.4

2. Hyperledger:v1.2

3. Docker:18.06.1-ce

4. Python:2.7.12

5. Go:go1.9.3 linux / amd64

6. curl:7.47.0

 

我们建议在适应代码的同时使用相同的版本。

 

确保先决条件安装正确后,请执行以下步骤:

 

cd path/to/repository/folder cd network

 

 

进入网络文件夹后,即可创建超级账本网络环境。 它将分别为您创建2个组织(Org1和Org2),Orderer每个组织有2个对等组。

 

Housekeeping

 

如果这是您第二次运行本教程,或者您已成功运行任何其他基于HyperLedger Fabric的代码,那么我们建议您首先运行以下命令:

 

./buildERC20TokenNetwork.sh down

 

 

它将要求确认:

 

Stopping for channel 'mychannel' with CLI timeout of '10' seconds and CLI delay of '3' seconds Continue? [Y/n]

 

 

按Y并继续。

 

注意:您可以使用以下命令检查Docker有多少个容器或卷正在运行:

 

• docker ps

• docker volume ls

 

如果使用脚本很难关闭容器和卷,请尝试运行以下命令:

• docker network prune

• docker volume prune

• docker rm -f $(docker ps -aq)

令牌网络设置

 

完成Housekeeping后,您就可以使用以下命令启动网络了:

 

https://attachfiles.oss-cn-beijing.aliyuncs.com/attachFiles/p2p_article/p2p_article/60879931011708034590551983448267/20190620151242537.png

 

执行可能需要一些时间(通常在90到120秒之间执行)。 但是,如果您在终端中看到以下日志,则表示它已成功执行,您的网络已准备就绪。

 

https://attachfiles.oss-cn-beijing.aliyuncs.com/attachFiles/p2p_article/p2p_article/66688977821654359116754503290668/20190620151301271.png

 

使用crypto-config.yaml文件在您的网络目录中名为crypto-config的文件夹中为HyperLedger的每个实体创建了所需的证书。

 

创建了channel.tx,genesis.block,Org1MSPanchors.tx和Org1MSPanchors.tx。

 

它还为以下内容创建了Docker容器和卷:

• peer0 and peer1 or Org1

• peer0 and peer1 of Org2

• orderer

• CLI

• chaincode

 

使用docker ps和docker volume ls检查它们。 我们还在Org1和Org2之间创建了一个频道名称mychannel,每个组织的同伴都是该频道的一部分。 然后在每个组织的peer0上安装我们的链代码并实例化我们的链代码,命名为mycc。 您可以使用以下方法查看相应对等/链代码的日志:

 

docker logs <peer identity> // type peer and then tab to see your options docker logs <chaincode identity> // type dev and then tab to see your options


注意:对于调试,您可以访问您的链代码和对等日志docker logs <按TAB查看选项>; 如果您没有看到链代码的容器(dev-peer0.org1.techracers.com-mycc-1.0),那么实例化我们的令牌链代码就会出现问题。

 

我们的代币

 

现在我们的chaincode已经启动并运行,让我们尝试一些getter和setter函数来更好地理解它。为此,我们需要输入我们创建的cli容器。

 

docker exec -it cli bash

 

 

你将会看到以下结果:

 

root@0e2b84a5cedc:/opt/gopath/src/github.com/hyperledger/fabric/peer#

 

 

getter函数

 

一旦进入了cli,就可以调用simpletoken中提供的getter函数。我们将逐一讨论您可以访问的每一个:

 

获得所有权人

 

此函数将返回令牌合同的所有者。现在是MSPID实例化了契约,您可以在这里看到它。

 

peer chaincode query -C mychannel -n mycc -c '{"Args":["getOwner"]}' Org1MSP

 

这里,mychannel是我们的通道名称,mycc是我们的chaincode的名称,如您所见,org1msp是我们chaincode的当前所有者。

 

getName

 

此函数将返回令牌合同的名称。它在实例化合同时被设置为简单令牌,您可以在这里看到它。

 

peer chaincode query -C mychannel -n mycc -c '{"Args":["getName"]}' Simple Token

 

如您所见,Simple Token是我们当前的令牌名称。

 

getSymbol

 

此函数将返回我们的令牌合约的符号。 在实例化合同时将其设置为SMT,您可以在此处查看

 

peer chaincode query -C mychannel -n mycc -c '{"Args":["getSymbol"]}' SMT

 

如您所见,SMT是我们当前的令牌符号。

 

getTotalSupply

 

此函数将返回令牌合同的总供应量。在设置之前,它默认为0。您可以在这里找到所需的逻辑。

 

peer chaincode query -C mychannel -n mycc -c '{"Args":["getTotalSupply"]}' 0

 

如你所见,0是我们目前的总供应量。

 

isMintingAllowed

 

此getter返回存储在Hyperledger上的IsMintingAllowed布尔值。它默认为未定义,直到设置一次。您可以在这里找到所需的逻辑。

 

peer chaincode query -C mychannel -n mycc -c '{"Args":["isMintingAllowed"]}' undefined

 

正如你所看到的,isMintingAllowed现在是未定义的。 一旦稍后设置,它将返回true或false。

 

getAllowance

 

此getter返回令牌所有者为Spender MSPID设置的津贴值。它将“input the mspid token”owner作为第一个参数,将“mspid of spender”作为第二个参数。在设置之前,它默认为0。

 

peer chaincode query -C mychannel -n mycc -c '{"Args":["getAllowance", "Org1MSP", "Org2MSP"]}' 0

 

如你所见,getallowance现在是0。稍后设置后,它将返回float。我们还要检查一下还有没有其他组合,看看它是否返回0。

 

peer chaincode query -C mychannel -n mycc -c '{"Args":["getAllowance", "Org2MSP", "Org1MSP"]}' 0

 

 

getBalanceOf

 

最后一个getter是getbalanceof函数,它返回我们输入的每个mspid的令牌平衡。如果mspid没有任何令牌平衡,它也默认为0。

 

https://attachfiles.oss-cn-beijing.aliyuncs.com/attachFiles/p2p_article/p2p_article/22742773736539868536182822139625/20190620151853367.png


来源:公众号:区块链研究实验室

 

联系我们

400-090-3910

(北京总部:全国统一咨询热线)

北京地址:北京市朝阳区领地OFFICE1号楼A座1403

上海分部:13911340419

上海地址:上海市宝山区泸太路6395号1_2层B区2440室

广州分部:13161766437

广州地址:广州市天河区广汕一路715号2号楼1-7楼405-5房

关注我们 了解最新动态消息
关注微信
关注微博
专题子站: